<template>
	<Form ref="formRef" :labelWidth="80" :rules="rules" :schema="schema">
		<template #sex="form">
			<el-radio-group v-model="form['sex']">
				<el-radio :label="1">{{ t('profile.user.man') }}</el-radio>
				<el-radio :label="2">{{ t('profile.user.woman') }}</el-radio>
			</el-radio-group>
		</template>
	</Form>
	<div class="fromSave"  @click="submit()">{{ t('common.save') }}</div>
</template>
<script lang="ts" setup>
import type {FormRules} from 'element-plus'
import {FormSchema} from '@/types/form'
import type {FormExpose} from '@/components/Form'
import {
  getUserProfile,
  updateUserProfile,
  UserProfileUpdateReqVO
} from '@/api/system/user/profile'
import {useUserStore} from '@/store/modules/user'

defineOptions({name: 'BasicInfo'})

const {t} = useI18n()
const message = useMessage() // 消息弹窗
const userStore = useUserStore()
// 表单校验
const rules = reactive<FormRules>({
  nickname: [{required: true, message: t('profile.rules.nickname'), trigger: 'blur'}],
  email: [
    {required: true, message: t('profile.rules.mail'), trigger: 'blur'},
    {
      type: 'email',
      message: t('profile.rules.truemail'),
      trigger: ['blur', 'change']
    }
  ],
  mobile: [
    {required: true, message: t('profile.rules.phone'), trigger: 'blur'},
    {
      pattern: /^1[3|4|5|6|7|8|9][0-9]\d{8}$/,
      message: t('profile.rules.truephone'),
      trigger: 'blur'
    }
  ]
})
const schema = reactive<FormSchema[]>([
  {
    field: 'nickname',
    label: t('profile.user.nickname'),
    component: 'Input'
  },
  {
    field: 'mobile',
    label: t('profile.user.mobile'),
    component: 'Input'
  },
  {
    field: 'email',
    label: t('profile.user.email'),
    component: 'Input'
  },
  {
    field: 'sex',
    label: t('profile.user.sex'),
    component: 'InputNumber',
    value: 0
  }
])
const formRef = ref<FormExpose>() // 表单 Ref
const submit = () => {
  const elForm = unref(formRef)?.getElFormRef()
  if (!elForm) return
  elForm.validate(async (valid) => {
    if (valid) {
      const data = unref(formRef)?.formModel as UserProfileUpdateReqVO
      await updateUserProfile(data)
      message.success(t('common.updateSuccess'))
      const profile = await init()
      userStore.setUserNicknameAction(profile.nickname)
    }
  })
}
const init = async () => {
  const res = await getUserProfile()
  unref(formRef)?.setValues(res)
  return res
}
onMounted(async () => {
  await init()
})
</script>
<style scoped lang="scss">
:deep(.el-radio__input.is-checked+.el-radio__label){
  color: var(--special-color);
}
:deep(.el-radio__input.is-checked .el-radio__inner){
  border-color: var(--special-color);
  background: var(--special-color);
}
.fromSave {
  $h: 36px;
  width: 96px;
  height: $h;
  line-height: $h;
  background: #0D0D0D;
  text-align: center;
  margin-left: 80px;
  font-weight: 400;
  font-size: 14px;
  color: #FFFFFF;
}
$wh: 40px;
:deep(.el-form-item--default .el-form-item__label) {
  height: $wh;
	line-height: $wh;
}

:deep(.el-input) {
  width: 360px;
  height: $wh;
}
</style>
